package com.fangcun.bean.api.seckill;

import java.util.ArrayList;
import java.util.Date;
import java.util.Iterator;
import java.util.List;

public class SmsFlashPromotionSessionExample {
	 protected String orderByClause;

	    protected boolean distinct;

	    protected List<Criteria> oredCriteria;

	    public SmsFlashPromotionSessionExample() {
	        oredCriteria = new ArrayList<Criteria>();
	    }

	    public void setOrderByClause(String orderByClause) {
	        this.orderByClause = orderByClause;
	    }

	    public String getOrderByClause() {
	        return orderByClause;
	    }

	    public void setDistinct(boolean distinct) {
	        this.distinct = distinct;
	    }

	    public boolean isDistinct() {
	        return distinct;
	    }

	    public List<Criteria> getOredCriteria() {
	        return oredCriteria;
	    }

	    public void or(Criteria criteria) {
	        oredCriteria.add(criteria);
	    }

	    public Criteria or() {
	        Criteria criteria = createCriteriaInternal();
	        oredCriteria.add(criteria);
	        return criteria;
	    }

	    public Criteria createCriteria() {
	        Criteria criteria = createCriteriaInternal();
	        if (oredCriteria.size() == 0) {
	            oredCriteria.add(criteria);
	        }
	        return criteria;
	    }

	    protected Criteria createCriteriaInternal() {
	        Criteria criteria = new Criteria();
	        return criteria;
	    }

	    public void clear() {
	        oredCriteria.clear();
	        orderByClause = null;
	        distinct = false;
	    }

	    protected abstract static class GeneratedCriteria {
	        protected List<Criterion> criteria;

	        protected GeneratedCriteria() {
	            super();
	            criteria = new ArrayList<Criterion>();
	        }

	        public boolean isValid() {
	            return criteria.size() > 0;
	        }

	        public List<Criterion> getAllCriteria() {
	            return criteria;
	        }

	        public List<Criterion> getCriteria() {
	            return criteria;
	        }

	        protected void addCriterion(String condition) {
	            if (condition == null) {
	                throw new RuntimeException("Value for condition cannot be null");
	            }
	            criteria.add(new Criterion(condition));
	        }

	        protected void addCriterion(String condition, Object value, String property) {
	            if (value == null) {
	                throw new RuntimeException("Value for " + property + " cannot be null");
	            }
	            criteria.add(new Criterion(condition, value));
	        }

	        protected void addCriterion(String condition, Object value1, Object value2, String property) {
	            if (value1 == null || value2 == null) {
	                throw new RuntimeException("Between values for " + property + " cannot be null");
	            }
	            criteria.add(new Criterion(condition, value1, value2));
	        }

	        protected void addCriterionForJDBCTime(String condition, Date value, String property) {
	            if (value == null) {
	                throw new RuntimeException("Value for " + property + " cannot be null");
	            }
	            addCriterion(condition, new java.sql.Time(value.getTime()), property);
	        }

	        protected void addCriterionForJDBCTime(String condition, List<Date> values, String property) {
	            if (values == null || values.size() == 0) {
	                throw new RuntimeException("Value list for " + property + " cannot be null or empty");
	            }
	            List<java.sql.Time> timeList = new ArrayList<java.sql.Time>();
	            Iterator<Date> iter = values.iterator();
	            while (iter.hasNext()) {
	                timeList.add(new java.sql.Time(iter.next().getTime()));
	            }
	            addCriterion(condition, timeList, property);
	        }

	        protected void addCriterionForJDBCTime(String condition, Date value1, Date value2, String property) {
	            if (value1 == null || value2 == null) {
	                throw new RuntimeException("Between values for " + property + " cannot be null");
	            }
	            addCriterion(condition, new java.sql.Time(value1.getTime()), new java.sql.Time(value2.getTime()), property);
	        }

	        public Criteria andIdIsNull() {
	            addCriterion("id is null");
	            return (Criteria) this;
	        }

	        public Criteria andIdIsNotNull() {
	            addCriterion("id is not null");
	            return (Criteria) this;
	        }

	        public Criteria andIdEqualTo(Long value) {
	            addCriterion("id =", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdNotEqualTo(Long value) {
	            addCriterion("id <>", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdGreaterThan(Long value) {
	            addCriterion("id >", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdGreaterThanOrEqualTo(Long value) {
	            addCriterion("id >=", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdLessThan(Long value) {
	            addCriterion("id <", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdLessThanOrEqualTo(Long value) {
	            addCriterion("id <=", value, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdIn(List<Long> values) {
	            addCriterion("id in", values, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdNotIn(List<Long> values) {
	            addCriterion("id not in", values, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdBetween(Long value1, Long value2) {
	            addCriterion("id between", value1, value2, "id");
	            return (Criteria) this;
	        }

	        public Criteria andIdNotBetween(Long value1, Long value2) {
	            addCriterion("id not between", value1, value2, "id");
	            return (Criteria) this;
	        }

	        public Criteria andNameIsNull() {
	            addCriterion("name is null");
	            return (Criteria) this;
	        }

	        public Criteria andNameIsNotNull() {
	            addCriterion("name is not null");
	            return (Criteria) this;
	        }

	        public Criteria andNameEqualTo(String value) {
	            addCriterion("name =", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameNotEqualTo(String value) {
	            addCriterion("name <>", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameGreaterThan(String value) {
	            addCriterion("name >", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameGreaterThanOrEqualTo(String value) {
	            addCriterion("name >=", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameLessThan(String value) {
	            addCriterion("name <", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameLessThanOrEqualTo(String value) {
	            addCriterion("name <=", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameLike(String value) {
	            addCriterion("name like", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameNotLike(String value) {
	            addCriterion("name not like", value, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameIn(List<String> values) {
	            addCriterion("name in", values, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameNotIn(List<String> values) {
	            addCriterion("name not in", values, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameBetween(String value1, String value2) {
	            addCriterion("name between", value1, value2, "name");
	            return (Criteria) this;
	        }

	        public Criteria andNameNotBetween(String value1, String value2) {
	            addCriterion("name not between", value1, value2, "name");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeIsNull() {
	            addCriterion("start_time is null");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeIsNotNull() {
	            addCriterion("start_time is not null");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeEqualTo(Date value) {
	            addCriterionForJDBCTime("start_time =", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeNotEqualTo(Date value) {
	            addCriterionForJDBCTime("start_time <>", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeGreaterThan(Date value) {
	            addCriterionForJDBCTime("start_time >", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeGreaterThanOrEqualTo(Date value) {
	            addCriterionForJDBCTime("start_time >=", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeLessThan(Date value) {
	            addCriterionForJDBCTime("start_time <", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeLessThanOrEqualTo(Date value) {
	            addCriterionForJDBCTime("start_time <=", value, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeIn(List<Date> values) {
	            addCriterionForJDBCTime("start_time in", values, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeNotIn(List<Date> values) {
	            addCriterionForJDBCTime("start_time not in", values, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeBetween(Date value1, Date value2) {
	            addCriterionForJDBCTime("start_time between", value1, value2, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andStartTimeNotBetween(Date value1, Date value2) {
	            addCriterionForJDBCTime("start_time not between", value1, value2, "startTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeIsNull() {
	            addCriterion("end_time is null");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeIsNotNull() {
	            addCriterion("end_time is not null");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeEqualTo(Date value) {
	            addCriterionForJDBCTime("end_time =", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeNotEqualTo(Date value) {
	            addCriterionForJDBCTime("end_time <>", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeGreaterThan(Date value) {
	            addCriterionForJDBCTime("end_time >", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeGreaterThanOrEqualTo(Date value) {
	            addCriterionForJDBCTime("end_time >=", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeLessThan(Date value) {
	            addCriterionForJDBCTime("end_time <", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeLessThanOrEqualTo(Date value) {
	            addCriterionForJDBCTime("end_time <=", value, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeIn(List<Date> values) {
	            addCriterionForJDBCTime("end_time in", values, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeNotIn(List<Date> values) {
	            addCriterionForJDBCTime("end_time not in", values, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeBetween(Date value1, Date value2) {
	            addCriterionForJDBCTime("end_time between", value1, value2, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andEndTimeNotBetween(Date value1, Date value2) {
	            addCriterionForJDBCTime("end_time not between", value1, value2, "endTime");
	            return (Criteria) this;
	        }

	        public Criteria andStatusIsNull() {
	            addCriterion("status is null");
	            return (Criteria) this;
	        }

	        public Criteria andStatusIsNotNull() {
	            addCriterion("status is not null");
	            return (Criteria) this;
	        }

	        public Criteria andStatusEqualTo(Integer value) {
	            addCriterion("status =", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusNotEqualTo(Integer value) {
	            addCriterion("status <>", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusGreaterThan(Integer value) {
	            addCriterion("status >", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusGreaterThanOrEqualTo(Integer value) {
	            addCriterion("status >=", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusLessThan(Integer value) {
	            addCriterion("status <", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusLessThanOrEqualTo(Integer value) {
	            addCriterion("status <=", value, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusIn(List<Integer> values) {
	            addCriterion("status in", values, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusNotIn(List<Integer> values) {
	            addCriterion("status not in", values, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusBetween(Integer value1, Integer value2) {
	            addCriterion("status between", value1, value2, "status");
	            return (Criteria) this;
	        }

	        public Criteria andStatusNotBetween(Integer value1, Integer value2) {
	            addCriterion("status not between", value1, value2, "status");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeIsNull() {
	            addCriterion("create_time is null");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeIsNotNull() {
	            addCriterion("create_time is not null");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeEqualTo(Date value) {
	            addCriterion("create_time =", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeNotEqualTo(Date value) {
	            addCriterion("create_time <>", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeGreaterThan(Date value) {
	            addCriterion("create_time >", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
	            addCriterion("create_time >=", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeLessThan(Date value) {
	            addCriterion("create_time <", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
	            addCriterion("create_time <=", value, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeIn(List<Date> values) {
	            addCriterion("create_time in", values, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeNotIn(List<Date> values) {
	            addCriterion("create_time not in", values, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeBetween(Date value1, Date value2) {
	            addCriterion("create_time between", value1, value2, "createTime");
	            return (Criteria) this;
	        }

	        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
	            addCriterion("create_time not between", value1, value2, "createTime");
	            return (Criteria) this;
	        }
	    }

	    public static class Criteria extends GeneratedCriteria {

	        protected Criteria() {
	            super();
	        }
	    }

	    public static class Criterion {
	        private String condition;

	        private Object value;

	        private Object secondValue;

	        private boolean noValue;

	        private boolean singleValue;

	        private boolean betweenValue;

	        private boolean listValue;

	        private String typeHandler;

	        public String getCondition() {
	            return condition;
	        }

	        public Object getValue() {
	            return value;
	        }

	        public Object getSecondValue() {
	            return secondValue;
	        }

	        public boolean isNoValue() {
	            return noValue;
	        }

	        public boolean isSingleValue() {
	            return singleValue;
	        }

	        public boolean isBetweenValue() {
	            return betweenValue;
	        }

	        public boolean isListValue() {
	            return listValue;
	        }

	        public String getTypeHandler() {
	            return typeHandler;
	        }

	        protected Criterion(String condition) {
	            super();
	            this.condition = condition;
	            this.typeHandler = null;
	            this.noValue = true;
	        }

	        protected Criterion(String condition, Object value, String typeHandler) {
	            super();
	            this.condition = condition;
	            this.value = value;
	            this.typeHandler = typeHandler;
	            if (value instanceof List<?>) {
	                this.listValue = true;
	            } else {
	                this.singleValue = true;
	            }
	        }

	        protected Criterion(String condition, Object value) {
	            this(condition, value, null);
	        }

	        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
	            super();
	            this.condition = condition;
	            this.value = value;
	            this.secondValue = secondValue;
	            this.typeHandler = typeHandler;
	            this.betweenValue = true;
	        }

	        protected Criterion(String condition, Object value, Object secondValue) {
	            this(condition, value, secondValue, null);
	        }
	    }
}
